home *** CD-ROM | disk | FTP | other *** search
/ Developer CD Series 1996 March: Reference Library / Dev.CD Mar 96 RL / Dev.CD Mar 96 RL.toast / Technical Documentation / develop / develop Issue 14 / develop Issue 14 code / Virtual Sphere 1.0.1.sea / Virtual Sphere 1.0.1 / Virtual Sphere Sample Code 1.1 / VirtualSphere.c < prev    next >
MacBinary  |  1993-03-25  |  4.0 KB  |  [TEXT/MPS ]

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: MacBinary (archive/macBinary).

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
1% dexvert MacBinary (archive/macBinary) fallback Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Thu Mar 25 13:00:37 1993, modified Thu Mar 25 13:00:37 1993, creator 'MPS ', type ASCII, 3359 bytes "VirtualSphere.c" , at 0xd9f 428 bytes resource default (weak)
99% file data default
74% TrID Macintosh plain text (MacBinary) default
25% TrID MacBinary 2 default (weak)
100% dearkID deark: macbinary default
100% siegfried fmt/1762 MacBinary (II) default
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[MPS ]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 0f 56 69 72 74 75 61 | 6c 53 70 68 65 72 65 2e |..Virtua|lSphere.|
|00000010| 63 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |c.......|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4d 50 53 | 20 01 00 00 00 00 00 00 |.TEXTMPS| .......|
|00000050| 00 00 00 00 00 0d 1f 00 | 00 01 ac a7 d7 a3 c5 a7 |........|........|
|00000060| d7 a3 c5 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 49 65 00 00 |........|....Ie..|
|00000080| 2f 2a a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |/*......|........|
|00000090| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|000000a0| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|000000b0| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|000000c0| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|000000d0| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|000000e0| a5 a5 a5 0d 2f 2a 20 56 | 69 72 74 75 61 6c 53 70 |..../* V|irtualSp|
|000000f0| 68 65 72 65 2e 63 0d 2f | 2a 0d 2f 2a 20 49 6d 70 |here.c./|*./* Imp|
|00000100| 6c 65 6d 65 6e 74 73 20 | 74 68 65 20 56 69 72 74 |lements |the Virt|
|00000110| 75 61 6c 20 53 70 68 65 | 72 65 20 61 6c 67 6f 72 |ual Sphe|re algor|
|00000120| 69 74 68 6d 20 66 6f 72 | 20 33 44 20 72 6f 74 61 |ithm for| 3D rota|
|00000130| 74 69 6f 6e 20 75 73 69 | 6e 67 20 61 20 32 44 20 |tion usi|ng a 2D |
|00000140| 69 6e 70 75 74 20 64 65 | 76 69 63 65 2e 0d 2f 2a |input de|vice../*|
|00000150| 20 53 65 65 20 70 61 70 | 65 72 20 22 41 20 53 74 | See pap|er "A St|
|00000160| 75 64 79 20 69 6e 20 49 | 6e 74 65 72 61 63 74 69 |udy in I|nteracti|
|00000170| 76 65 20 33 2d 44 20 52 | 6f 74 61 74 69 6f 6e 20 |ve 3-D R|otation |
|00000180| 55 73 69 6e 67 20 32 2d | 44 20 43 6f 6e 74 72 6f |Using 2-|D Contro|
|00000190| 6c 20 44 65 76 69 63 65 | 73 22 20 62 79 0d 2f 2a |l Device|s" by./*|
|000001a0| 20 4d 69 63 68 61 65 6c | 20 43 68 65 6e 2c 20 53 | Michael| Chen, S|
|000001b0| 2e 20 4a 6f 79 20 4d 6f | 75 6e 74 66 6f 72 64 20 |. Joy Mo|untford |
|000001c0| 61 6e 64 20 41 62 69 67 | 61 69 6c 20 53 65 6c 6c |and Abig|ail Sell|
|000001d0| 65 6e 20 70 75 62 6c 69 | 73 68 65 64 20 69 6e 20 |en publi|shed in |
|000001e0| 74 68 65 20 41 43 4d 20 | 53 69 67 67 72 61 70 68 |the ACM |Siggraph|
|000001f0| 20 27 38 38 0d 2f 2a 20 | 70 72 6f 63 65 65 64 69 | '88./* |proceedi|
|00000200| 6e 67 73 20 28 56 6f 6c | 75 6d 65 20 32 32 2c 20 |ngs (Vol|ume 22, |
|00000210| 4e 75 6d 62 65 72 20 34 | 2c 20 41 75 67 75 73 74 |Number 4|, August|
|00000220| 20 31 39 38 38 29 20 66 | 6f 72 20 6d 6f 72 65 20 | 1988) f|or more |
|00000230| 64 65 74 61 69 6c 2e 20 | 20 54 68 65 20 63 6f 64 |detail. | The cod|
|00000240| 65 20 68 65 72 65 0d 2f | 2a 20 70 72 6f 76 69 64 |e here./|* provid|
|00000250| 65 73 20 61 20 6d 75 63 | 68 20 73 69 6d 70 6c 65 |es a muc|h simple|
|00000260| 72 20 69 6d 70 6c 65 6d | 65 6e 74 61 74 69 6f 6e |r implem|entation|
|00000270| 20 74 68 61 6e 20 74 68 | 61 74 20 64 65 73 63 72 | than th|at descr|
|00000280| 69 62 65 64 20 69 6e 20 | 74 68 65 20 70 61 70 65 |ibed in |the pape|
|00000290| 72 2e 0d 2f 2a 0d 2f 2a | 20 41 75 74 68 6f 72 3a |r../*./*| Author:|
|000002a0| 20 4d 69 63 68 61 65 6c | 20 43 68 65 6e 2c 20 48 | Michael| Chen, H|
|000002b0| 75 6d 61 6e 20 49 6e 74 | 65 72 66 61 63 65 20 47 |uman Int|erface G|
|000002c0| 72 6f 75 70 20 2f 20 41 | 54 47 0d 2f 2a 20 43 6f |roup / A|TG./* Co|
|000002d0| 70 79 72 69 67 68 74 20 | a9 20 31 39 39 31 2d 31 |pyright |. 1991-1|
|000002e0| 39 39 33 20 41 70 70 6c | 65 20 43 6f 6d 70 75 74 |993 Appl|e Comput|
|000002f0| 65 72 2c 20 49 6e 63 2e | 20 20 41 6c 6c 20 72 69 |er, Inc.| All ri|
|00000300| 67 68 74 73 20 72 65 73 | 65 72 76 65 64 2e 0d 2f |ghts res|erved../|
|00000310| 2a 0d 2f 2a 20 50 61 72 | 74 20 6f 66 20 56 69 72 |*./* Par|t of Vir|
|00000320| 74 75 61 6c 20 53 70 68 | 65 72 65 20 53 61 6d 70 |tual Sph|ere Samp|
|00000330| 6c 65 20 43 6f 64 65 20 | 52 65 6c 65 61 73 65 20 |le Code |Release |
|00000340| 76 31 2e 31 0d 2f 2a a5 | a5 a5 a5 a5 a5 a5 a5 a5 |v1.1./*.|........|
|00000350| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|00000360| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|00000370| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|00000380| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|00000390| a5 a5 a5 a5 a5 a5 a5 a5 | a5 a5 a5 a5 a5 a5 a5 a5 |........|........|
|000003a0| a5 a5 a5 a5 a5 a5 a5 a5 | 2a 2f 0d 0d 23 69 66 6e |........|*/..#ifn|
|000003b0| 64 65 66 09 5f 5f 56 49 | 52 54 55 41 4c 53 50 48 |def.__VI|RTUALSPH|
|000003c0| 45 52 45 5f 5f 0d 23 69 | 6e 63 6c 75 64 65 20 22 |ERE__.#i|nclude "|
|000003d0| 56 69 72 74 75 61 6c 53 | 70 68 65 72 65 2e 68 22 |VirtualS|phere.h"|
|000003e0| 0d 23 65 6e 64 69 66 0d | 0d 2f 2a 20 4c 6f 63 61 |.#endif.|./* Loca|
|000003f0| 6c 20 72 6f 75 74 69 6e | 65 20 2a 2f 0d 73 74 61 |l routin|e */.sta|
|00000400| 74 69 63 20 76 6f 69 64 | 20 50 6f 69 6e 74 4f 6e |tic void| PointOn|
|00000410| 55 6e 69 74 53 70 68 65 | 72 65 20 28 50 6f 69 6e |UnitSphe|re (Poin|
|00000420| 74 09 70 2c 0d 09 09 09 | 09 09 09 09 20 20 20 50 |t.p,....|.... P|
|00000430| 6f 69 6e 74 09 63 75 65 | 43 65 6e 74 65 72 2c 0d |oint.cue|Center,.|
|00000440| 09 09 09 09 09 09 09 20 | 20 20 49 6e 74 65 67 65 |....... | Intege|
|00000450| 72 09 63 75 65 52 61 64 | 69 75 73 2c 0d 09 09 09 |r.cueRad|ius,....|
|00000460| 09 09 09 09 20 20 20 43 | 50 6f 69 6e 74 33 44 09 |.... C|Point3D.|
|00000470| 2a 76 29 3b 0d 0d 2f 2a | 3d 3d 3d 3d 3d 3d 3d 3d |*v);../*|========|
|00000480| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000490| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000004a0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000004b0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000004c0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000004d0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 0d 2f 2a 20 56 69 72 |========|=./* Vir|
|000004e0| 74 75 61 6c 53 70 68 65 | 72 65 0d 2f 2a 20 0d 2f |tualSphe|re./* ./|
|000004f0| 2a 20 44 65 74 65 72 6d | 69 6e 65 20 74 68 65 20 |* Determ|ine the |
|00000500| 61 78 69 73 20 61 6e 64 | 20 61 6e 67 6c 65 20 6f |axis and| angle o|
|00000510| 66 20 72 6f 74 61 74 69 | 6f 6e 20 66 72 6f 6d 20 |f rotati|on from |
|00000520| 74 68 65 20 6c 61 73 74 | 20 32 20 6c 6f 63 61 74 |the last| 2 locat|
|00000530| 69 6f 6e 73 20 6f 66 20 | 74 68 65 20 6d 6f 75 73 |ions of |the mous|
|00000540| 65 0d 2f 2a 20 72 65 6c | 61 74 69 76 65 20 74 6f |e./* rel|ative to|
|00000550| 20 74 68 65 20 56 69 72 | 74 75 61 6c 20 53 70 68 | the Vir|tual Sph|
|00000560| 65 72 65 20 63 75 65 20 | 63 69 72 63 6c 65 2e 20 |ere cue |circle. |
|00000570| 20 0d 2f 2a 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d | ./*----|--------|
|00000580| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000590| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000005a0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000005b0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000005c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000005d0| 2d 2d 2d 2d 2d 2a 2f 0d | 70 61 73 63 61 6c 20 76 |-----*/.|pascal v|
|000005e0| 6f 69 64 20 56 69 72 74 | 75 61 6c 53 70 68 65 72 |oid Virt|ualSpher|
|000005f0| 65 20 28 50 6f 69 6e 74 | 09 70 2c 09 0d 09 09 09 |e (Point|.p,.....|
|00000600| 09 09 09 20 20 20 50 6f | 69 6e 74 09 71 2c 0d 09 |... Po|int.q,..|
|00000610| 09 09 09 09 09 20 20 20 | 50 6f 69 6e 74 09 63 75 |..... |Point.cu|
|00000620| 65 43 65 6e 74 65 72 2c | 0d 09 09 09 09 09 09 20 |eCenter,|....... |
|00000630| 20 20 49 6e 74 65 67 65 | 72 09 63 75 65 52 61 64 | Intege|r.cueRad|
|00000640| 69 75 73 2c 0d 09 09 09 | 09 09 09 20 20 20 4d 61 |ius,....|... Ma|
|00000650| 74 72 69 78 34 44 20 72 | 6f 74 61 74 69 6f 6e 4d |trix4D r|otationM|
|00000660| 61 74 72 69 78 29 0d 7b | 0d 09 43 50 6f 69 6e 74 |atrix).{|..CPoint|
|00000670| 33 44 09 09 6f 70 2c 20 | 6f 71 3b 0d 09 0d 09 2f |3D..op, |oq;..../|
|00000680| 2a 20 50 72 6f 6a 65 63 | 74 20 6d 6f 75 73 65 20 |* Projec|t mouse |
|00000690| 70 6f 69 6e 74 73 20 74 | 6f 20 33 2d 44 20 70 6f |points t|o 3-D po|
|000006a0| 69 6e 74 73 20 6f 6e 20 | 74 68 65 20 2b 7a 20 68 |ints on |the +z h|
|000006b0| 65 6d 69 73 70 68 65 72 | 65 20 6f 66 20 61 20 75 |emispher|e of a u|
|000006c0| 6e 69 74 0d 09 20 2a 20 | 73 70 68 65 72 65 2e 20 |nit.. * |sphere. |
|000006d0| 2a 2f 0d 09 50 6f 69 6e | 74 4f 6e 55 6e 69 74 53 |*/..Poin|tOnUnitS|
|000006e0| 70 68 65 72 65 20 28 70 | 2c 20 63 75 65 43 65 6e |phere (p|, cueCen|
|000006f0| 74 65 72 2c 20 63 75 65 | 52 61 64 69 75 73 2c 20 |ter, cue|Radius, |
|00000700| 26 6f 70 29 3b 0d 09 50 | 6f 69 6e 74 4f 6e 55 6e |&op);..P|ointOnUn|
|00000710| 69 74 53 70 68 65 72 65 | 20 28 71 2c 20 63 75 65 |itSphere| (q, cue|
|00000720| 43 65 6e 74 65 72 2c 20 | 63 75 65 52 61 64 69 75 |Center, |cueRadiu|
|00000730| 73 2c 20 26 6f 71 29 3b | 0d 0d 09 2f 2a 20 43 6f |s, &oq);|.../* Co|
|00000740| 6e 73 69 64 65 72 20 74 | 68 65 20 74 77 6f 20 70 |nsider t|he two p|
|00000750| 72 6f 6a 65 63 74 65 64 | 20 70 6f 69 6e 74 73 20 |rojected| points |
|00000760| 61 73 20 76 65 63 74 6f | 72 73 20 66 72 6f 6d 20 |as vecto|rs from |
|00000770| 74 68 65 20 63 65 6e 74 | 65 72 20 6f 66 20 74 68 |the cent|er of th|
|00000780| 65 20 0d 09 20 2a 20 75 | 6e 69 74 20 73 70 68 65 |e .. * u|nit sphe|
|00000790| 72 65 2e 20 43 6f 6d 70 | 75 74 65 20 74 68 65 20 |re. Comp|ute the |
|000007a0| 72 6f 74 61 74 69 6f 6e | 20 6d 61 74 72 69 78 20 |rotation| matrix |
|000007b0| 74 68 61 74 20 77 69 6c | 6c 20 74 72 61 6e 73 66 |that wil|l transf|
|000007c0| 6f 72 6d 20 76 65 63 74 | 6f 72 0d 09 20 2a 20 6f |orm vect|or.. * o|
|000007d0| 70 20 74 6f 20 6f 71 2e | 20 2a 2f 0d 09 53 65 74 |p to oq.| */..Set|
|000007e0| 52 6f 74 61 74 69 6f 6e | 4d 61 74 72 69 78 20 28 |Rotation|Matrix (|
|000007f0| 72 6f 74 61 74 69 6f 6e | 4d 61 74 72 69 78 2c 20 |rotation|Matrix, |
|00000800| 26 6f 70 2c 20 26 6f 71 | 29 3b 0d 7d 0d 0d 2f 2a |&op, &oq|);.}../*|
|00000810| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000820| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000830| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000840| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000850| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000860| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000870| 3d 0d 2f 2a 20 50 6f 69 | 6e 74 4f 6e 55 6e 69 74 |=./* Poi|ntOnUnit|
|00000880| 53 70 68 65 72 65 0d 2f | 2a 0d 2f 2a 20 50 72 6f |Sphere./|*./* Pro|
|00000890| 6a 65 63 74 20 61 20 32 | 44 20 70 6f 69 6e 74 20 |ject a 2|D point |
|000008a0| 6f 6e 20 61 20 63 69 72 | 63 6c 65 20 74 6f 20 61 |on a cir|cle to a|
|000008b0| 20 33 44 20 70 6f 69 6e | 74 20 6f 6e 20 74 68 65 | 3D poin|t on the|
|000008c0| 20 2b 7a 20 68 65 6d 69 | 73 70 68 65 72 65 20 6f | +z hemi|sphere o|
|000008d0| 66 20 61 20 75 6e 69 74 | 20 73 70 68 65 72 65 2e |f a unit| sphere.|
|000008e0| 0d 2f 2a 20 49 66 20 74 | 68 65 20 32 44 20 70 6f |./* If t|he 2D po|
|000008f0| 69 6e 74 20 69 73 20 6f | 75 74 73 69 64 65 20 74 |int is o|utside t|
|00000900| 68 65 20 63 69 72 63 6c | 65 2c 20 69 74 20 69 73 |he circl|e, it is|
|00000910| 20 66 69 72 73 74 20 6d | 61 70 70 65 64 20 74 6f | first m|apped to|
|00000920| 20 74 68 65 20 6e 65 61 | 72 65 73 74 20 70 6f 69 | the nea|rest poi|
|00000930| 6e 74 20 6f 6e 0d 2f 2a | 20 74 68 65 20 63 69 72 |nt on./*| the cir|
|00000940| 63 6c 65 20 62 65 66 6f | 72 65 20 70 72 6f 6a 65 |cle befo|re proje|
|00000950| 63 74 69 6f 6e 2e 0d 2f | 2a 20 4f 72 74 68 6f 67 |ction../|* Orthog|
|00000960| 72 61 70 68 69 63 20 70 | 72 6f 6a 65 63 74 69 6f |raphic p|rojectio|
|00000970| 6e 20 69 73 20 75 73 65 | 64 2c 20 74 68 6f 75 67 |n is use|d, thoug|
|00000980| 68 20 74 65 63 68 6e 69 | 63 61 6c 6c 79 20 74 68 |h techni|cally th|
|00000990| 65 20 66 69 65 6c 64 20 | 6f 66 20 76 69 65 77 20 |e field |of view |
|000009a0| 6f 66 20 74 68 65 20 63 | 61 6d 65 72 61 0d 2f 2a |of the c|amera./*|
|000009b0| 20 73 68 6f 75 6c 64 20 | 62 65 20 74 61 6b 65 6e | should |be taken|
|000009c0| 20 69 6e 74 6f 20 61 63 | 63 6f 75 6e 74 2e 20 20 | into ac|count. |
|000009d0| 48 6f 77 65 76 65 72 2c | 20 74 68 65 20 64 69 73 |However,| the dis|
|000009e0| 63 72 65 70 61 6e 63 79 | 20 69 73 20 6e 65 67 6c |crepancy| is negl|
|000009f0| 65 67 69 62 6c 65 2e 0d | 2f 2a 2d 2d 2d 2d 2d 2d |egible..|/*------|
|00000a00| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000a10| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000a20| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000a30| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000a40| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000a50| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2a 2f 0d 73 74 |--------|---*/.st|
|00000a60| 61 74 69 63 20 76 6f 69 | 64 20 50 6f 69 6e 74 4f |atic voi|d PointO|
|00000a70| 6e 55 6e 69 74 53 70 68 | 65 72 65 20 28 50 6f 69 |nUnitSph|ere (Poi|
|00000a80| 6e 74 09 70 2c 0d 09 09 | 09 09 09 09 09 20 20 20 |nt.p,...|..... |
|00000a90| 50 6f 69 6e 74 09 63 75 | 65 43 65 6e 74 65 72 2c |Point.cu|eCenter,|
|00000aa0| 0d 09 09 09 09 09 09 09 | 20 20 20 49 6e 74 65 67 |........| Integ|
|00000ab0| 65 72 09 63 75 65 52 61 | 64 69 75 73 2c 0d 09 09 |er.cueRa|dius,...|
|00000ac0| 09 09 09 09 09 20 20 20 | 43 50 6f 69 6e 74 33 44 |..... |CPoint3D|
|00000ad0| 09 2a 76 29 0d 7b 0d 09 | 52 65 61 6c 09 6c 65 6e |.*v).{..|Real.len|
|00000ae0| 67 74 68 3b 0d 09 52 65 | 61 6c 09 6c 65 6e 67 74 |gth;..Re|al.lengt|
|00000af0| 68 53 71 61 72 65 64 3b | 0d 09 0d 09 2f 2a 20 54 |hSqared;|..../* T|
|00000b00| 75 72 6e 20 74 68 65 20 | 6d 6f 75 73 65 20 70 6f |urn the |mouse po|
|00000b10| 69 6e 74 73 20 69 6e 74 | 6f 20 76 65 63 74 6f 72 |ints int|o vector|
|00000b20| 73 20 72 65 6c 61 74 69 | 76 65 20 74 6f 20 74 68 |s relati|ve to th|
|00000b30| 65 20 63 65 6e 74 65 72 | 20 6f 66 20 74 68 65 20 |e center| of the |
|00000b40| 63 69 72 63 6c 65 0d 09 | 20 2a 20 61 6e 64 20 6e |circle..| * and n|
|00000b50| 6f 72 6d 61 6c 69 7a 65 | 20 74 68 65 6d 2e 20 20 |ormalize| them. |
|00000b60| 4e 6f 74 65 20 77 65 20 | 6e 65 65 64 20 74 6f 20 |Note we |need to |
|00000b70| 66 6c 69 70 20 74 68 65 | 20 79 20 76 61 6c 75 65 |flip the| y value|
|00000b80| 20 73 69 6e 63 65 20 74 | 68 65 20 33 44 20 63 6f | since t|he 3D co|
|00000b90| 6f 72 64 69 6e 61 74 65 | 0d 09 20 2a 20 68 61 73 |ordinate|.. * has|
|00000ba0| 20 70 6f 73 69 74 69 76 | 65 20 79 20 67 6f 69 6e | positiv|e y goin|
|00000bb0| 67 20 75 70 2e 20 2a 2f | 0d 09 76 2d 3e 78 20 3d |g up. */|..v->x =|
|00000bc0| 20 28 52 65 61 6c 29 20 | 20 28 70 2e 68 20 2d 20 | (Real) | (p.h - |
|00000bd0| 63 75 65 43 65 6e 74 65 | 72 2e 68 29 20 2f 20 28 |cueCente|r.h) / (|
|00000be0| 52 65 61 6c 29 20 63 75 | 65 52 61 64 69 75 73 3b |Real) cu|eRadius;|
|00000bf0| 0d 09 76 2d 3e 79 20 3d | 20 28 52 65 61 6c 29 20 |..v->y =| (Real) |
|00000c00| 2d 28 70 2e 76 20 2d 20 | 63 75 65 43 65 6e 74 65 |-(p.v - |cueCente|
|00000c10| 72 2e 76 29 20 2f 20 28 | 52 65 61 6c 29 20 63 75 |r.v) / (|Real) cu|
|00000c20| 65 52 61 64 69 75 73 3b | 0d 0d 09 6c 65 6e 67 74 |eRadius;|...lengt|
|00000c30| 68 53 71 61 72 65 64 20 | 3d 20 76 2d 3e 78 2a 76 |hSqared |= v->x*v|
|00000c40| 2d 3e 78 20 2b 20 76 2d | 3e 79 2a 76 2d 3e 79 3b |->x + v-|>y*v->y;|
|00000c50| 0d 09 0d 09 2f 2a 20 50 | 72 6f 6a 65 63 74 20 74 |..../* P|roject t|
|00000c60| 68 65 20 70 6f 69 6e 74 | 20 6f 6e 74 6f 20 74 68 |he point| onto th|
|00000c70| 65 20 73 70 68 65 72 65 | 2c 20 61 73 73 75 6d 69 |e sphere|, assumi|
|00000c80| 6e 67 20 6f 72 74 68 6f | 67 72 61 70 68 69 63 20 |ng ortho|graphic |
|00000c90| 70 72 6f 6a 65 63 74 69 | 6f 6e 2e 0d 09 20 2a 20 |projecti|on... * |
|00000ca0| 50 6f 69 6e 74 73 20 62 | 65 79 6f 6e 64 20 74 68 |Points b|eyond th|
|00000cb0| 65 20 76 69 72 74 75 61 | 6c 20 73 70 68 65 72 65 |e virtua|l sphere|
|00000cc0| 20 61 72 65 20 6e 6f 72 | 6d 61 6c 69 7a 65 64 20 | are nor|malized |
|00000cd0| 6f 6e 74 6f 20 0d 09 20 | 2a 20 65 64 67 65 20 6f |onto .. |* edge o|
|00000ce0| 66 20 74 68 65 20 73 70 | 68 65 72 65 20 28 77 68 |f the sp|here (wh|
|00000cf0| 65 72 65 20 7a 20 3d 20 | 30 29 2e 20 2a 2f 0d 09 |ere z = |0). */..|
|00000d00| 69 66 20 28 6c 65 6e 67 | 74 68 53 71 61 72 65 64 |if (leng|thSqared|
|00000d10| 20 3c 20 31 2e 30 29 20 | 7b 0d 09 09 76 2d 3e 7a | < 1.0) |{...v->z|
|00000d20| 20 3d 20 73 71 72 74 20 | 28 31 2e 30 20 2d 20 6c | = sqrt |(1.0 - l|
|00000d30| 65 6e 67 74 68 53 71 61 | 72 65 64 29 3b 0d 09 7d |engthSqa|red);..}|
|00000d40| 20 65 6c 73 65 20 7b 0d | 09 09 6c 65 6e 67 74 68 | else {.|..length|
|00000d50| 20 3d 20 73 71 72 74 20 | 28 6c 65 6e 67 74 68 53 | = sqrt |(lengthS|
|00000d60| 71 61 72 65 64 29 3b 0d | 09 09 76 2d 3e 78 20 2f |qared);.|..v->x /|
|00000d70| 3d 20 6c 65 6e 67 74 68 | 3b 0d 09 09 76 2d 3e 79 |= length|;...v->y|
|00000d80| 20 2f 3d 20 6c 65 6e 67 | 74 68 3b 0d 09 09 76 2d | /= leng|th;...v-|
|00000d90| 3e 7a 20 3d 20 30 2e 30 | 3b 0d 09 7d 0d 7d 0d 00 |>z = 0.0|;..}.}..|
|00000da0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000db0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000dc0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000dd0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000de0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000df0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000e00| 00 00 01 00 00 00 01 6e | 00 00 00 6e 00 00 00 3e |.......n|...n...>|
|00000e10| 00 00 01 87 00 00 a5 48 | 1e 2a 00 00 06 f1 00 00 |.......H|.*......|
|00000e20| 01 87 00 00 a5 48 1e 2a | 00 00 0a 45 00 00 01 93 |.....H.*|...E....|
|00000e30| 0f 56 69 72 74 75 61 6c | 53 70 68 65 72 65 2e 63 |.Virtual|Sphere.c|
|00000e40| 02 00 00 00 54 45 58 54 | 4d 50 53 20 01 00 03 0c |....TEXT|MPS ....|
|00000e50| 00 00 54 45 58 54 4d 50 | 53 20 01 00 03 0c 00 40 |..TEXTMP|S .....@|
|00000e60| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000e70| 00 00 a5 61 82 76 00 00 | 0d 1f 00 00 01 ac 07 03 |...a.v..|........|
|00000e80| 00 00 01 95 00 00 a5 48 | 1e 2b 00 00 08 54 00 00 |.......H|.+...T..|
|00000e90| 01 87 00 00 a5 48 1e 2b | 00 00 07 0c 00 00 01 87 |.....H.+|........|
|00000ea0| 00 00 a5 48 1d df 00 00 | 28 de 00 00 00 39 00 01 |...H....|(....9..|
|00000eb0| a5 48 1d df 00 00 28 e2 | 00 00 01 9d 00 01 a5 48 |.H....(.|.......H|
|00000ec0| 1d d2 00 00 04 18 00 00 | 00 02 00 00 a5 48 1d d3 |........|.....H..|
|00000ed0| 00 00 04 1d 00 00 00 02 | 00 00 a5 48 1d df 00 00 |........|...H....|
|00000ee0| 28 e3 00 00 01 d2 00 00 | a5 48 1d d8 00 00 29 72 |(.......|.H....)r|
|00000ef0| 00 00 00 02 00 00 a5 48 | 1d d3 00 00 27 d9 00 00 |.......H|....'...|
|00000f00| 00 00 00 48 00 09 4d 6f | 6e 61 63 6f 00 77 69 6e |...H..Mo|naco.win|
|00000f10| 64 6f 77 29 0d 7b 0d 09 | 53 65 74 43 75 72 73 6f |dow).{..|SetCurso|
|00000f20| 72 28 2a 67 72 61 00 06 | 00 04 00 87 01 e3 03 58 |r(*gra..|.......X|
|00000f30| 04 24 00 87 01 e3 03 58 | 04 24 a7 d5 5c d6 00 00 |.$.....X|.$..\...|
|00000f40| 02 c5 00 00 02 c5 00 00 | 00 00 01 00 00 00 00 1e |........|........|
|00000f50| 00 87 01 e3 03 58 04 24 | 00 87 01 e3 03 58 04 24 |.....X.$|.....X.$|
|00000f60| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000f70| 01 00 00 00 01 6e 00 00 | 00 6e 00 00 00 3e 00 cf |.....n..|.n...>..|
|00000f80| 97 1c 0d 98 00 00 00 1c | 00 3e 00 00 4d 50 53 52 |........|.>..MPSR|
|00000f90| 00 01 00 0a 03 ed ff ff | 00 00 00 00 00 00 00 00 |........|........|
|00000fa0| 03 f0 ff ff 00 00 00 4c | 00 d1 8e dc 00 00 00 00 |.......L|........|
|00000fb0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000fc0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000fd0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000fe0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000ff0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+